netfilter: nfnetlink_cthelper: Add missing permission checks
authorKevin Cernekee <cernekee@chromium.org>
Sun, 3 Dec 2017 20:12:45 +0000 (12:12 -0800)
committerBen Hutchings <ben@decadent.org.uk>
Sun, 14 Jan 2018 19:45:05 +0000 (19:45 +0000)
commit035fcdf51f65ee68f8a4d299df5300954a86ab34
tree7782f772baba7ee62592b9dda2168f51c68bb1b7
parent6a2f385f6972c7f222aad7b781bd91261bd919f3
netfilter: nfnetlink_cthelper: Add missing permission checks

The capability check in nfnetlink_rcv() verifies that the caller
has CAP_NET_ADMIN in the namespace that "owns" the netlink socket.
However, nfnl_cthelper_list is shared by all net namespaces on the
system.  An unprivileged user can create user and net namespaces
in which he holds CAP_NET_ADMIN to bypass the netlink_net_capable()
check:

    $ nfct helper list
    nfct v1.4.4: netlink error: Operation not permitted
    $ vpnns -- nfct helper list
    {
            .name = ftp,
            .queuenum = 0,
            .l3protonum = 2,
            .l4protonum = 6,
            .priv_data_len = 24,
            .status = enabled,
    };

Add capable() checks in nfnetlink_cthelper, as this is cleaner than
trying to generalize the solution.

Signed-off-by: Kevin Cernekee <cernekee@chromium.org>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Gbp-Pq: Topic bugfix/all
Gbp-Pq: Name netfilter-nfnetlink_cthelper-add-missing-permission-.patch
net/netfilter/nfnetlink_cthelper.c